草庐IT

sql - NoSQL系统保存关系数据

全部标签

ruby-on-rails - Rails 应用程序中的动态角色和权限系统

我需要在我的Rails应用程序中创建基于角色的权限系统。我对CanCan非常满意,但主要问题是它必须是动态的,这样管理员就必须能够分配权限并创建新角色。权限可以是简单的Controller/操作限制,也可以是数据相关的,例如一些用户只能编辑他们自己的配置文件,而一些用户可以编辑特定组中所有用户的配置文件。如果允许管理员创建新权限,那就太好了。我正在考虑的是在数据库中存储一个Controller/操作,以及一些与数据相关的限制(我在这里对定义它们的方式感到很困惑)。那么,您能否给我一些建议,组织权限的最佳方式是什么?非常感谢任何想法 最佳答案

ruby-on-rails - ActiveRecord 与两个数据库对话?

我们最近改进了一个项目,希望将我们所有的旧数据带入新系统。问题在于架构略有不同,因此无法直接导入SQL。由于一些非规范化和数据库更改,我们需要在数据准备好导入之前对数据进行一些处理。我希望是这样的:OldUser.all.eachdo|ou|NewUser.create({:first_name=>ou.first_name:last_name=>ou.last_name:login=>ou.login:company_name=>ou.company.name})end在上面的示例中,OldUser正在从旧数据库读取数据,而NewUser正在处理新数据库。我需要两组模型(新的和旧的)

ruby-on-rails - Heroku 上的数据库连接

哇,我已经被困在这个问题上好几天了。我无法连接到Heroku上的database.yml。我在使用Cedar和ruby​​1.9.2。我的开发和测试数据库是sqlite3,生产数据库是postgreSQL以应对Cedar规则。这是我的ruby​​脚本中的代码:Rails.env.production??(env="production"):(env="development")dbconfig=YAML::load(File.open('config/database.yml'))[env]ActiveRecord::Base.establish_connection(dbconfig

ruby - 有没有办法查看 Sequel 表达式将生成的原始 SQL?

假设我有一个像这样的Sequel表达式:db.select(:id).from(:some_table).where(:foo=>5)有没有办法获取这将生成的SQL字符串(即"SELECTidFROMsome_tableWHEREfoo=5")?我注意到对上述表达式的结果调用inspect或to_s包括生成的SQL,但不确定如何直接访问它。以及不返回数据集的Sequel表达式如何,例如:db.from(:some_table).update(:foo=>5)是否可以在执行之前从中看到SQL? 最佳答案 你可以在数据集上调用sql:d

ruby - 应该在系统范围内还是在用户级别安装 rbenv?

我正在构建一个vagrant设置,其中一部分是安装rbenv。我正在使用librarian-chef来管理我所有的ChefRecipe,它会安装rbenv和ruby​​-build。但是,当我尝试通过ssh进入我的VagrantVM并键入ruby-v时,我得到了标准系统安装的ruby1.8.7(2012-02-08patchlevel358)[x86_64-linux]。考虑到可能没有安装rbenv,我尝试运行rbenvversions,但实际上已经安装了rbenv:vagrant@precise64:~$rbenvversions*system(setby/opt/rbenv/ver

ruby - 使用 VCR 过滤敏感数据

我正在使用VCRgem来记录http交互并在将来重播它们。我想在uri请求中过滤掉我的实际密码值。以下是uri的示例:http://services.somesite.com/Services.asmx/CabinsUsername=long&Password=john&StartDate=03%2F22%2F2012&EndDate=03%2F29%2F2012虽然这里提供了解释,但我自己尝试了几次后仍然不确定如何去做:https://www.relishapp.com/myronmarston/vcr/v/2-0-0/docs/configuration/filter-sensit

ruby-on-rails - Rails 3.2 Postgres 保存错误 "ActiveRecord::StatementInvalid: PG::Error: ERROR: Syntax error near ' T' 在位置 5"

当我尝试将特定类保存到数据库时,我的应用开始抛出错误。我不确定到底是什么原因导致这种情况开始发生-过去几天我一直遇到各种数据库问题....无论如何,我的模型似乎工作正常(它正在正确计算所有before_save值),但随后它尝试保存到数据库并爆炸。SQL(0.8ms)INSERTINTO"portfolios"("correlation_matrix","created_at","data","mean_return","std_dev","updated_at","weights")VALUES($1,$2,$3,$4,$5,$6,$7)RETURNING"id"[["correla

ruby-on-rails - Rails:PG::InsufficientPrivilege:错误:关系 schema_migrations 的权限被拒绝

我正在尝试在Rails中创建数据库。在Postgres中,我看到了开发和测试数据库,但是,我遇到了权限错误。我试过点击此链接,但对我不起作用。错误:PG::InsufficientPrivilege:错误:关系schema_migrations的权限被拒绝:SELECT"schema_migrations".*FROM"schema_migrations"Rails:permissiondeniedforrelationschema_migrationsdefault:&defaultadapter:postgresqlencoding:unicodepool:5host:localh

ruby-on-rails - 保存对象时 after_save 如何工作

如果我执行以下操作:@user.name="John"@user.url="www.john.com"@user.save如果我使用after_save@user.url="www.johnseena.com"@user.save当我这样做时会发生什么?我相信它应该保存值,因为“after_save”回调。 最佳答案 在我看来,如果你在after_save回调中调用save函数,除非你在开始处设置保护,否则它将陷入递归。像这样classUser但是,除了放置守卫外,您还可以使用update_columndefchange_urlup

ruby-on-rails - 数组上的 rails where() sql 查询

我会尽可能详细地解释这一点。我对用户帖子有疑问:@selected_posts=Posts.where(:category=>"棒球")我想写下面的语句。这是伪术语:User.where(用户在@selected_posts中有帖子)请记住,我设置了多对多关系,因此post.user可用。有什么想法吗?/编辑@posts_matches=User.includes(@selected_posts).map{|user|[user.company_name,user.posts.count,user.username]}.sort基本上,我需要上面的工作,以便它使用在selected_p